---
title: Référence de l'API des importations de configuration
sidebar:
  label: 'astro:config'
i18nReady: true
tableOfContents:
  minHeadingLevel: 2
  maxHeadingLevel: 6
---

import Since from '~/components/Since.astro';

<p><Since v="5.7.0" /></p>

Ce module virtuel `astro:config` expose une version non exhaustive, sérialisable et assurant la sûreté du typage de la configuration Astro. Deux sous-modules permettent d'accéder à différents sous-ensembles de vos valeurs de configuration : [`/client`](#importations-depuis-astroconfigclient) et [`/server`](#importations-depuis-astroconfigserver).

Toutes les valeurs de configuration disponibles sont accessibles depuis `astro:config/server`. Cependant, pour le code exécuté côté client, seules les valeurs exposées par `astro:config/client` seront disponibles. Cela protège vos informations en ne rendant accessibles qu'une partie des données au client.

## Importations depuis `astro:config/client`

```js
import {
  i18n, 
  trailingSlash,
  base,
  build,
  site,
  compressHTML,
} from "astro:config/client";
```

Utilisez ce sous-module pour le code côté client :

```js title="src/utils.js" ins={1} ins="trailingSlash"
import { trailingSlash } from "astro:config/client";

function addForwardSlash(path) {
  if (trailingSlash === "always") {
    return path.endsWith("/") ? path : path + "/"
  } else {
    return path
  }
}
```

En savoir plus sur les importations de configuration disponibles à partir de `astro:config/client` :

- [`i18n`](/fr/reference/configuration-reference/#i18n)
- [`trailingSlash`](/fr/reference/configuration-reference/#trailingslash)
- [`base`](/fr/reference/configuration-reference/#base)
- [`build.format`](/fr/reference/configuration-reference/#buildformat)
- [`site`](/fr/reference/configuration-reference/#site)
- [`compressHTML`](/fr/reference/configuration-reference/#compresshtml)



## Importations depuis `astro:config/server`

```js
import {
  i18n, 
  trailingSlash,
  base,
  build,
  site,
  srcDir,
  cacheDir,
  outDir,
  publicDir,
  root,
  compressHTML,
} from "astro:config/server";
```

Ces importations incluent tout ce qui est disponible à partir de `astro:config/client` ainsi que des informations sensibles supplémentaires sur la configuration de votre système de fichiers qu'il n'est pas sûr d'exposer au client.

Utilisez ce sous-module pour le code côté serveur :

```js title="astro.config.mjs"
import { integration } from "./integration.mjs";

export default defineConfig({
    integrations: [
      integration(),
    ]
});
```

```js title="integration.mjs" ins={1} ins="outDir"
import { outDir } from "astro:config/server";
import { writeFileSync } from "node:fs";
import { fileURLToPath } from "node:url";

export default function() {
  return {
    name: "internal-integration",
    hooks: {
      "astro:build:done": () => {
        let file = new URL("result.json", outDir);
        // générer des données à partir d'une opération
        let data = JSON.stringify([]);
        writeFileSync(fileURLToPath(file), data, "utf-8");
      }
    }
  }
}
```

En savoir plus sur les importations de configuration disponibles à partir de `astro:config/server` :

- [`i18n`](/fr/reference/configuration-reference/#i18n)
- [`trailingSlash`](/fr/reference/configuration-reference/#trailingslash)
- [`base`](/fr/reference/configuration-reference/#base)
- [`build.format`](/fr/reference/configuration-reference/#buildformat)
- [`build.client`](/fr/reference/configuration-reference/#buildclient)
- [`build.server`](/fr/reference/configuration-reference/#buildserver)
- [`site`](/fr/reference/configuration-reference/#site)
- [`srcDir`](/fr/reference/configuration-reference/#srcdir)
- [`cacheDir`](/fr/reference/configuration-reference/#cachedir)
- [`outDir`](/fr/reference/configuration-reference/#outdir)
- [`publicDir`](/fr/reference/configuration-reference/#publicdir)
- [`root`](/fr/reference/configuration-reference/#root)
- [`compressHTML`](/fr/reference/configuration-reference/#compresshtml)
